// 导出一个axios的实例  而且这个实例要有请求拦截器 响应拦截器
import axios from 'axios'
import store from '@/store'
import router from '@/router'
import { Message } from 'element-ui'
const service = axios.create({
  baseURL: process.env.VUE_APP_BASE_API
  // baseURL: 'http://ihrm.itheima.net'
}) // 创建一个axios的实例
// service.interceptors.request.use() // 请求拦截器
// service.interceptors.response.use() // 响应拦截器
// 添加请求拦截器
service.interceptors.request.use(function(config) {
  // 在发送请求之前做些什么
  // console.log(config)
  const token = store.state.user.token
  if (token) {
    config.headers.Authorization = 'Bearer ' + token
  }
  return config
}, function(error) {
  // 对请求错误做些什么
  return Promise.reject(error)
})

// 添加响应拦截器
service.interceptors.response.use(function(response) {
  // 对响应数据做点什么
  // console.log(response, 'response')
  if (!response.data.success) {
    return Promise.reject(response.data.message)
  }
  return response.data
}, function(error) {
  // 超出 2xx 范围的状态码都会触发该函数。
  // 对响应错误做点什么
  console.dir(error)
  if (error.response.status === 401 && error.response.data.code === 10002) {
    Message.error('登录已过期 请重新登陆')
    store.dispatch('user/layout')
    // console.log(router.currentRoute.fullPath)
    const url = encodeURIComponent(router.currentRoute.fullPath)
    // console.log(url)
    router.push(`/login?url=${url}`)
  }
  return Promise.reject(error)
})
export default service // 导出axios实例
